<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <script>
        // 1.块级作用域
        if(true){
            let i = 0
        }
        console.log(i);//i is not defined
        
        // for循环
        for(let i = 0;i<5;i++){
            // 我们之前在用var的时候出现的问题是，var声明的变量只有全局作用作用域和函数作用域，所以出现了打印的全是5的情况。而let存在着块作用域，也就是说每一次循环都会有一个新的块产生，每次循环里的i也都不同。所以就解决了这个问题
            setTimeout(() => {
                console.log(i);
            }, i);
        }
    </script>
</body>
</html>